﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using Controller2.BLL;

namespace Controller2.Models.ViewModels
{
    public class SaidaViewModel
    {
        public int ID { get; set; }
        public string Midia { get; set; }
        public string DataPrevista { get; set; }
        public string ValorPrevisto { get; set; }
        public string DataPagamento { get; set; }
        public string ValorPagamento { get; set; }
        public int IdFornecedor { get; set; }
        public string Fornecedor { get; set; }

        public IEnumerable<SaidaViewModel> Listar(ControllerBDModelContainer db, string texto, int filtro)
        {
            IEnumerable<SaidaViewModel> model;
            int codigo = 0;
            if (filtro == 1)
            {
                if (!Int32.TryParse(texto, out codigo))
                {
                    filtro = 0;
                    texto = "";
                }
            }
            if (string.IsNullOrWhiteSpace(texto) || texto.Equals("Digite sua pesquisa"))
            {
                filtro = 0;
                texto = "";
            }
            switch (filtro)
            {
                default:
                    model = from c in SaidaBll.GetAllSaidas(db)
                            orderby c.IdSaida
                            select new SaidaViewModel
                            {
                                ID = c.IdSaida,
                                Midia = c.Midia != null ? c.Midia.Nome : "",
                                DataPrevista = c.DataPrevista.ToShortDateString(),
                                ValorPrevisto = c.ValorPrevisto.ToString("N2"),
                                DataPagamento = c.DataPagamento == null ? "" : Convert.ToDateTime(c.DataPagamento).ToShortDateString(),
                                ValorPagamento = c.ValorPagamento == null ? "" : Convert.ToDecimal(c.ValorPagamento).ToString("N2"),
                                Fornecedor = c.Fornecedor.NomePessoa
                            };
                    break;
                case 1:
                    model = from c in SaidaBll.GetAllSaidas(db)
                            orderby c.IdSaida
                            where c.IdSaida == codigo
                            select new SaidaViewModel
                            {
                                ID = c.IdSaida,
                                Midia = c.Midia != null ? c.Midia.Nome : "",
                                DataPrevista = c.DataPrevista.ToShortDateString(),
                                ValorPrevisto = c.ValorPrevisto.ToString("N2"),
                                DataPagamento = c.DataPagamento == null ? "" : Convert.ToDateTime(c.DataPagamento).ToShortDateString(),
                                ValorPagamento = c.ValorPagamento == null ? "" : Convert.ToDecimal(c.ValorPagamento).ToString("N2"),
                                Fornecedor = c.Fornecedor.NomePessoa
                            };
                    break;
            }

			return model.OrderBy(o => o.ID); ;
        }
    }
}